@@ -12,6 +12,7 @@ |
||
| 12 | 12 |
<!-- bower:js --> |
| 13 | 13 |
<script src="../bower_components/jquery/dist/jquery.min.js"></script> |
| 14 | 14 |
<script src="../bower_components/angular/angular.js"></script> |
| 15 |
+ <script src="../bower_components/angular-ui-router/release/angular-ui-router.min.js"></script> |
|
| 15 | 16 |
<script src="../bower_components/angular-animate/angular-animate.js"></script> |
| 16 | 17 |
<script src="../bower_components/angular-cookies/angular-cookies.js"></script> |
| 17 | 18 |
<script src="../bower_components/angular-resource/angular-resource.js"></script> |
@@ -39,6 +40,7 @@ |
||
| 39 | 40 |
<script src="scripts/controllers/slideshow.js"></script> |
| 40 | 41 |
<script src="scripts/directives/wallop-slider.js"></script> |
| 41 | 42 |
<script src="scripts/services/data.js"></script> |
| 43 |
+ <script src="scripts/services/getController.js"></script> |
|
| 42 | 44 |
|
| 43 | 45 |
|
| 44 | 46 |
|
@@ -69,7 +71,7 @@ |
||
| 69 | 71 |
</ul> |
| 70 | 72 |
</div> |
| 71 | 73 |
|
| 72 |
- <div ng-view></div> |
|
| 74 |
+ <div ui-view></div> |
|
| 73 | 75 |
|
| 74 | 76 |
|
| 75 | 77 |
</body> |
@@ -10,10 +10,10 @@ |
||
| 10 | 10 |
*/ |
| 11 | 11 |
angular |
| 12 | 12 |
.module('goApp', [
|
| 13 |
+ 'ui.router', |
|
| 13 | 14 |
'ngAnimate', |
| 14 | 15 |
'ngCookies', |
| 15 | 16 |
'ngResource', |
| 16 |
- 'ngRoute', |
|
| 17 | 17 |
'ngSanitize', |
| 18 | 18 |
'ngTouch', |
| 19 | 19 |
'famous.angular', |
@@ -23,10 +23,10 @@ angular |
||
| 23 | 23 |
'goApp.background', |
| 24 | 24 |
'goApp.navigation', |
| 25 | 25 |
'goApp.slideshow', |
| 26 |
- 'goApp.slider' |
|
| 26 |
+ 'goApp.slider', |
|
| 27 | 27 |
]) |
| 28 | 28 |
|
| 29 |
- .config(['$routeProvider', '$httpProvider', function($routeProvider, $httpProvider) {
|
|
| 29 |
+ .config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) {
|
|
| 30 | 30 |
|
| 31 | 31 |
// Configs |
| 32 | 32 |
//Enable cross domain calls |
@@ -34,17 +34,18 @@ angular |
||
| 34 | 34 |
//Remove the header used to identify ajax call that would prevent CORS from working |
| 35 | 35 |
//delete $httpProvider.defaults.headers.common['X-Requested-With']; |
| 36 | 36 |
|
| 37 |
- // Routes |
|
| 38 |
- $routeProvider |
|
| 39 |
- .when('/', {
|
|
| 40 |
- templateUrl: 'views/index.html', |
|
| 41 |
- controller: 'IndexController' |
|
| 42 |
- }) |
|
| 43 |
- .when('/:slideshowId', {
|
|
| 44 |
- templateUrl: 'views/slideshow.html', |
|
| 45 |
- controller: 'SlideshowController' |
|
| 46 |
- }) |
|
| 47 |
- .otherwise({
|
|
| 48 |
- redirectTo: '/' |
|
| 49 |
- }); |
|
| 37 |
+ // UI router |
|
| 38 |
+ $stateProvider |
|
| 39 |
+ .state('/', {
|
|
| 40 |
+ url: "/", |
|
| 41 |
+ templateUrl: 'views/index.html', |
|
| 42 |
+ controller: 'IndexController' |
|
| 43 |
+ }) |
|
| 44 |
+ .state('slideshow', {
|
|
| 45 |
+ url: "/:slideshow", |
|
| 46 |
+ templateUrl: "views/slideshow.html", |
|
| 47 |
+ controller: 'SlideshowController' |
|
| 48 |
+ }) |
|
| 49 |
+ |
|
| 50 |
+ |
|
| 50 | 51 |
}]) |
@@ -10,6 +10,8 @@ |
||
| 10 | 10 |
angular.module('goApp.slideshow', ['ngFx', 'ngAnimate', 'goApp.data'])
|
| 11 | 11 |
.controller('SlideshowController',['$scope', '$rootScope', '$famous', '$timeline', '$location', '$route', '$timeout', 'Data', function ($scope, $rootScope, $famous, $timeline, $location, $route, $timeout, Data) {
|
| 12 | 12 |
|
| 13 |
+ console.log('> Loading Slideshow')
|
|
| 14 |
+ |
|
| 13 | 15 |
// Get Page Data |
| 14 | 16 |
var link = $location.url() |
| 15 | 17 |
$scope.pageData = Data.getPageData(link); |
@@ -30,8 +32,9 @@ angular.module('goApp.slideshow', ['ngFx', 'ngAnimate', 'goApp.data'])
|
||
| 30 | 32 |
$scope.fadeOut = function() {
|
| 31 | 33 |
$scope.showView = false; |
| 32 | 34 |
$timeout(function(){
|
| 35 |
+ $scope.showView = false; |
|
| 33 | 36 |
$location.path("/");
|
| 34 |
- },2000); |
|
| 37 |
+ },800); |
|
| 35 | 38 |
} |
| 36 | 39 |
|
| 37 | 40 |
$scope.index = 0; |
@@ -0,0 +1,17 @@ |
||
| 1 |
+"use strict" |
|
| 2 |
+ |
|
| 3 |
+angular.module('goApp.getController', ['goApp.data'])
|
|
| 4 |
+ .provider('getController', function () {
|
|
| 5 |
+ this.$get = function ($location, Data) {
|
|
| 6 |
+ return function () {
|
|
| 7 |
+ var data = Data.getPageData($location.path) |
|
| 8 |
+ if(data.controller == undefined){
|
|
| 9 |
+ console.log('> Loading controller: SlideshowController')
|
|
| 10 |
+ return 'SlideshowController'; |
|
| 11 |
+ } else {
|
|
| 12 |
+ console.log('> Loading controller: ' + data.controller)
|
|
| 13 |
+ return data.controller; |
|
| 14 |
+ } |
|
| 15 |
+ } |
|
| 16 |
+ }; |
|
| 17 |
+ }); |
@@ -1,16 +1,17 @@ |
||
| 1 |
-<div class="layer-content fx-fade-normal fx-easing-quad fx-speed-500" ng-show="showView"> |
|
| 2 |
- <a class="btn-menu fixed-top-right" ng-click="fadeOut()">X</a> |
|
| 3 |
- <p class="fixed-bottom-center"><span class="slide-title">{{pageData.slides[index].title}}</span></p>
|
|
| 4 |
- <div id="slider" class="Aligner"> |
|
| 5 |
- <div class="Aligner-item"> |
|
| 6 |
- <wallop-slider |
|
| 7 |
- ng-show="slider" |
|
| 8 |
- data-images="images" |
|
| 9 |
- data-animation="fade" |
|
| 10 |
- data-current-item-index="index" |
|
| 11 |
- data-on-previous="updateTsPrevious()" |
|
| 12 |
- data-on-next="updateTsNext()" |
|
| 13 |
- ></wallop-slider> |
|
| 1 |
+ |
|
| 2 |
+ <div class="layer-content fx-fade-normal fx-easing-quad fx-speed-500" ng-show="showView"> |
|
| 3 |
+ <a class="btn-menu fixed-top-right" ng-click="fadeOut()">X</a> |
|
| 4 |
+ <p class="fixed-bottom-center"><span class="slide-title">{{pageData.slides[index].title}}</span></p>
|
|
| 5 |
+ <div id="slider" class="Aligner"> |
|
| 6 |
+ <div class="Aligner-item"> |
|
| 7 |
+ <wallop-slider |
|
| 8 |
+ ng-show="slider" |
|
| 9 |
+ data-images="images" |
|
| 10 |
+ data-animation="fade" |
|
| 11 |
+ data-current-item-index="index" |
|
| 12 |
+ data-on-previous="updateTsPrevious()" |
|
| 13 |
+ data-on-next="updateTsNext()" |
|
| 14 |
+ ></wallop-slider> |
|
| 15 |
+ </div> |
|
| 14 | 16 |
</div> |
| 15 | 17 |
</div> |
| 16 |
-</div> |
@@ -29,7 +29,9 @@ |
||
| 29 | 29 |
"angular-touch": "^1.3.0", |
| 30 | 30 |
"jQuery": "~2.1.4", |
| 31 | 31 |
"ngFx": "~1.1.0", |
| 32 |
- "famous-bkimagesurface": "~1.0.3" |
|
| 32 |
+ "famous-bkimagesurface": "~1.0.3", |
|
| 33 |
+ "angular-ui": "~0.4.0", |
|
| 34 |
+ "angular-ui-router": "~0.2.15" |
|
| 33 | 35 |
}, |
| 34 | 36 |
"resolutions": {
|
| 35 | 37 |
"angular": "1.3.8" |